CS 342302 Operating Systems

Fall Semester 2021

Prof. Pai H. Chou

Weekly Review 2

The questions here serve the purpose of reviewing concepts from the lecture, and expect the concepts to be tested on the midterm and final. However, they are by no means exhaustive. Anything covered in the lecture and projects can be tested.

## 1. Definitions and Short Answers - week 2 (9/20 lectures)

1. What is the **kernel** part of an OS?
2. What is a **system program**?
3. Is a **web browser** part of an OS? part of the kernel? part of system programs?
4. **Middleware** is a set of software frameworks that provide additional services to what kind of users? What would be some example features?
5. As a resource manager, what kinds of resources does an OS manage?
6. What does **API** stand for? What kinds of API does an OS provide?
7. What is a **bootloader**? How is it related to an OS?
8. How does a bootloader load an OS?
9. How does a CPU **send a command** to a device controller?
10. From textbook (page 7) A **device controller** maintains some "**local buffer storage**" and a set of **special-purpose registers**". Where do these storage and registers reside? On CPU? in main memory? in cache? outside CPU?
11. What is a **device driver**? hardware or software? part of the OS or in an application program? What does it do?
12. What does **IRQ** stand for, and what is its purpose?
13. How does a program for 8051 know when the UART has received a byte?
14. What does **ISR** stand for, and when is it invoked?
15. What is an **interrupt vector**?
16. What is an **interrupt vector table**?
17. How does a processor decide which ISR to execute when there are multiple I/O devices?
18. How does a processor continue executing the user program after an ISR finishes?
19. What is a **nested interrupt**?
20. What is **interrupt chaining**? (page 10 in textbook) Why is it useful?
21. How does the OS protect CPU time as a resource by preventing a user program from hogging the CPU without making a system call?
22. What is **volatile memory** vs. **nonvolatile memory**? What are examples of each kind?
23. What is the purpose of a **cache**? Can a processor run without a cache?
24. What is the principle of **locality**? What are **two kinds of locality**?
25. What does **DMA** stand for, and why is it used?
26. What are steps in a DMA setup, transfer, and completion?

## EdSim51 and 8051 - week 2 (9/22 lecture)

1. What are the **(direct) addresses** of the 8051 general-purpose I/O (GPIO) ports P0, P1, P2, and P3?
2. What is the meaning of each of the following instructions in 8051?
	1. MOV A, #1
	2. MOV A, 1
	3. MOV A, R1
	4. MOV A, @R1
	5. MOV R1, A
	6. MOV R1, #1
	7. MOV R1, 34H
	8. MOV @R1, A
	9. MOV @R1, #1
	10. MOV @R1, 34H
	11. MOV 34H, A
	12. MOV 34H, #56H
	13. MOV 34H, 56H
	14. MOV 34H, R1
	15. MOV 34H, @R1
3. Are the following allowed? If not, what assembly code does the intended operation, if any?
	1. MOV R1, R2
	2. MOV A, A
	3. MOV #20, R3
4. What is a **port latch**?
5. What does it mean that 8051 GPIO ports are **bit addressable**?
6. What is the Intel assembly notation for "bit 3 of port P2"?
7. What is the meaning of
SETB P1.1
CLR P2.3
and why can't the same effect be achieved using a MOV instruction?
8. If you want to set individual bits of a GPIO port without using SETB and CLR instructions, what instruction can you use? Hint: [8051 User's Guide](https://drive.google.com/file/d/1FJEKnCuO2oDEANp8tDqkzQHOFy4-SKB6/view), Table 3 on page 1-11, "Logical Instructions", find a combination of ANL, ORL, XRL instructions. What **addressing modes** should be used with these instructions? Use these instructions to implement the two bit set/clear instructions in the previous question.
9. What is a **label** in an assembly language program?
10. Given the sample program for setting P3<4:3>:
Top: SETB P3.4
 SETB P3.3
 MOV P1, #24H
 CLR P3.3
 MOV P1, #24H
 CLR P3.4
 SETB P3.3
 MOV P1, #24H
 CLR P3.3
 MOV P1, #24H
 SJMP Top
Rewrite it in C by filling in the blank \_\_\_\_ below:
 **int** i;
 **for** (i = 0; i < 4; i++) {
 P3 = \_\_\_\_\_; // you may change = into &=, |=, etc
INT0 }
11. What does the following Intel 8051 assembly code do?
Data1: DB "Hello world"
	1. Does it occupy any memory? In which space? (CODE? IDATA? XDATA?)
	2. What is the closest equivalent statement in C?
	3. Is the assembly version null-terminated? How do you find out?
12. Given the Intel 8051 assembly code:
Data2: DB 25
	1. How many bytes does the 25 data occupy?
	2. What kind of address is Data2? In other words, what space (CODE, IDATA, XDATA, etc) and how many bytes?
13. Given the Intel 8051 assembly code
 COUNT EQU 25
	1. How many bytes does the above line occupy in the assembled code, if any and in which memory?
	2. What is the equivalent statement in C?
14. If you want to display the digit "7" on the seven-segment LED with the additional vertical line on the upper left instead of just an upside-down L, what value do you write to P1?
15. What is the advantage of using CLR A instruction over MOV A, #0 instruction, which does exactly the same thing (assign A = 0)? Hint: look up how these instructions are encoded.
16. What is the difference between A and ACC in 8051 assembly? Why do I have to say PUSH ACC and cannot say PUSH A? (Similarly POP ACC but not POP A)?
17. What is the effect of PUSH and POP on the stack? Explain in terms of the stack, i.e., SP and the memory location pointed by SP.
18. What does LCALL Display do (where Display is a code label)? Explain in terms of the program counter and the stack.
19. What does the RET instruction do? Does RET know if the subroutine was originally called by LCALL or ACALL instruction?
20. What does the following instruction do:
MOV DPTR, #LEDdata
Assume LEDdata corresponds to address 0x2468, what is the new value of DPL and DPH?
21. What is the meaning of the instruction
MOVC A, @A+DPTR
and how is it different from
MOV A, @Ri
where Ri is either R0 or R1?
22. On a UART, what does RxD stand for? What is TxD?
23. How should the RxD and TxD signals of one system be connected to the RxD and TxD signals of another system that it communicated with?
24. On the 8051, what is the purpose of the SBUF special-function register? What happens when you move data **to** SBUF? move data **from** SBUF?
25. How does a program know when there is valid data to be read from SBUF?
26. Why is it necessary to clear RI bit after reading from SBUF?
27. What is the meaning of the code
Here: JNB RI, Here

Rewrite this assembly code as a C statement.

1. What does **4800 baud** mean for a UART?
2. On the 8051, what is the **interrupt vector** (i.e., address of the ISR) for Reset?
3. The interrupt vector for interrupt is at 03H, which leaves only 3 bytes for the interrupt vector for Reset. Why is 3 bytes sufficient?
4. The interrupt vector after 03H is 0BH, leaving only 8 bytes for the the INT0. Why is 8 bytes sufficient?
5. When is the TI flag set to 1 by the UART?
6. When the UART's ISR is invoked, is it caused by RI or TI becoming 1? Can it be both?
7. What is the purpose of the EA bit, which stands for "enable all (interrupts)"?

## 3. Short Assembly Programs

1. Modify the Display subroutine so that it not only displays the digit but also switches to the next 7-segment LED. It just needs to a different digit at a time; does not need to keep all four.

Display: MOV DPTR, #LEDdata
 MOVC A, @A+DPTR
 ;; your code to increment the LED ID,
 ;; which is defined by P3.3 and P3.4
 MOV P1, A ;; light up the selected 7-segment LED
 RET
LEDdata: DB 0c0H,0F9H,0A4H,0B0H,99H,92H,82H,0F8H,80H,90H

Test your code with polling version of UART (e.g., slide 12 of 02-EdSim51-IO.pdf). Remember to initialize UART and Timer as well as P3.3 and P3.4. Try it out by typing digit characters into the Tx window and click send.

1. Convert your code to interrupt version, shown on slide, based on slide 26-27.